CS2022 Datapath Design Part B

Jack Cassidy | Student No. 1432 0816 | jacassid@tcd.ie

# VHDL Code

This section consists of code from the previous assignment, modified slightly in some cases to improve readability or functionality, and new code written to implement a full Datapath design.

## Decoder 3 to 8:

**entity** decoder\_3to8 **is**

**Port** **(** A **:** **in** STD\_LOGIC\_VECTOR**(**2 **downto** 0**);**

Q0 **:** **out** STD\_LOGIC**;**

Q1 **:** **out** STD\_LOGIC**;**

Q2 **:** **out** STD\_LOGIC**;**

Q3 **:** **out** STD\_LOGIC**;**

Q4 **:** **out** STD\_LOGIC**;**

Q5 **:** **out** STD\_LOGIC**;**

Q6 **:** **out** STD\_LOGIC**;**

Q7 **:** **out** STD\_LOGIC**);**

**end** decoder\_3to8**;**

**architecture** Behavioral **of** decoder\_3to8 **is**

**begin**

Q0**<=((**not A**(**0**))** and **(**not A**(**1**))** and **(**not A**(**2**)))** **after** 1ns**;**

Q1**<=(**A**(**0**)** and **(**not A**(**1**))** and **(**not A**(**2**)))** **after** 1ns**;**

Q2**<=((**not A**(**0**))** and A**(**1**)** and **(**not A**(**2**)))** **after** 1ns**;**

Q3**<=(**A**(**0**)** and A**(**1**)** and **(**not A**(**2**)))** **after** 1ns**;**

Q4**<=((**not A**(**0**))** and **(**not A**(**1**))** and A**(**2**))** **after** 1ns**;**

Q5**<=(**A**(**0**)** and **(**not A**(**1**))** and A**(**2**))** **after** 1ns**;**

Q6**<=((**not A**(**0**))** and A**(**1**)** and A**(**2**))** **after** 1ns**;**

Q7**<=(**A**(**0**)** and A**(**1**)** and A**(**2**))** **after** 1ns**;**

**end** Behavioral**;**

## Mux 2 16 bit:

**entity** mux2\_16bit **is**

**Port** **(** IN0 **:** **in** STD\_LOGIC\_VECTOR**(**15 **downto** 0**);**

IN1 **:** **in** STD\_LOGIC\_VECTOR**(**15 **downto** 0**);**

S **:** **in** STD\_LOGIC**;**

Z **:** **out** STD\_LOGIC\_VECTOR**(**15 **downto** 0**));**

**end** mux2\_16bit**;**

**architecture** Behavioral **of** mux2\_16bit **is**

**begin**

Z **<=** IN0 **after** 1ns **when** S **=** '0' **else**

IN1 **after** 1ns **when** S **=** '1' **else**

x"0000" **after** 1ns**;**

**end** Behavioral**;**

## Mux 3 1 bit:

**entity** mux3\_1bit **is**

**Port** **(** IN0 **:** **in** STD\_LOGIC**;**

IN1 **:** **in** STD\_LOGIC**;**

IN2 **:** **in** STD\_LOGIC**;**

S **:** **in** STD\_LOGIC\_VECTOR**(**1 **downto** 0**);**

Z **:** **out** STD\_LOGIC**);**

**end** mux3\_1bit**;**

**architecture** Behavioral **of** mux3\_1bit **is**

**begin**

Z **<=** IN0 **after** 1ns **when** S**(**0**)** **=** '0' and S**(**1**)** **=** '0' **else**

IN1 **after** 1ns **when** S**(**0**)** **=** '1' and S**(**1**)** **=** '0' **else**

IN2 **after** 1ns **when** S**(**0**)** **=** '0' and S**(**1**)** **=** '1' **else**

'0' **after** 1ns**;**

**end** Behavioral**;**

## Mux 4 16 bit:

**entity** mux4\_16bit **is**

**Port** **(** IN0 **:** **in** STD\_LOGIC\_VECTOR**(**15 **downto** 0**);**

IN1 **:** **in** STD\_LOGIC\_VECTOR**(**15 **downto** 0**);**

IN2 **:** **in** STD\_LOGIC\_VECTOR**(**15 **downto** 0**);**

IN3 **:** **in** STD\_LOGIC\_VECTOR**(**15 **downto** 0**);**

S **:** **in** STD\_LOGIC\_VECTOR**(**1 **downto** 0**);**

Z **:** **out** STD\_LOGIC\_VECTOR**(**15 **downto** 0**));**

**end** mux4\_16bit**;**

**architecture** Behavioral **of** mux4\_16bit **is**

**begin**

Z **<=** IN0 **after** 1ns **when** S**(**0**)=**'0' and S**(**1**)=**'0' **else**

IN1 **after** 1ns **when** S**(**0**)=**'1' and S**(**1**)=**'0' **else**

IN2 **after** 1ns **when** S**(**0**)=**'0' and S**(**1**)=**'1' **else**

IN3 **after** 1ns **when** S**(**0**)=**'1' and S**(**1**)=**'1' **else**

x"0000" **after** 1ns**;**

**end** Behavioral**;**

## Mux 8 16 bit:

**entity** mux8\_16bit **is**

**Port** **(** IN0 **:** **in** STD\_LOGIC\_VECTOR **(**15 **downto** 0**);**

IN1 **:** **in** STD\_LOGIC\_VECTOR **(**15 **downto** 0**);**

IN2 **:** **in** STD\_LOGIC\_VECTOR **(**15 **downto** 0**);**

IN3 **:** **in** STD\_LOGIC\_VECTOR **(**15 **downto** 0**);**

IN4 **:** **in** STD\_LOGIC\_VECTOR **(**15 **downto** 0**);**

IN5 **:** **in** STD\_LOGIC\_VECTOR **(**15 **downto** 0**);**

IN6 **:** **in** STD\_LOGIC\_VECTOR **(**15 **downto** 0**);**

IN7 **:** **in** STD\_LOGIC\_VECTOR **(**15 **downto** 0**);**

S **:** **in** STD\_LOGIC\_VECTOR**(**2 **downto** 0**);**

Z **:** **out** STD\_LOGIC\_VECTOR **(**15 **downto** 0**));**

**end** mux8\_16bit**;**

**architecture** Behavioral **of** mux8\_16bit **is**

**begin**

Z **<=** IN0 **after** 1ns **when** S**(**0**)=**'0' and S**(**1**)=**'0' and S**(**2**)=**'0' **else**

IN1 **after** 1ns **when** S**(**0**)=**'1' and S**(**1**)=**'0' and S**(**2**)=**'0' **else**

IN2 **after** 1ns **when** S**(**0**)=**'0' and S**(**1**)=**'1' and S**(**2**)=**'0' **else**

IN3 **after** 1ns **when** S**(**0**)=**'1' and S**(**1**)=**'1' and S**(**2**)=**'0' **else**

IN4 **after** 1ns **when** S**(**0**)=**'0' and S**(**1**)=**'0' and S**(**2**)=**'1' **else**

IN5 **after** 1ns **when** S**(**0**)=**'1' and S**(**1**)=**'0' and S**(**2**)=**'1' **else**

IN6 **after** 1ns **when** S**(**0**)=**'0' and S**(**1**)=**'1' and S**(**2**)=**'1' **else**

IN7 **after** 1ns **when** S**(**0**)=**'1' and S**(**1**)=**'1' and S**(**2**)=**'1' **else**

"0000000000000000" **after** 1ns**;**

**end** Behavioral**;**

## Register 16 bit:

**entity** reg16 **is**

**Port** **(** D **:** **in** STD\_LOGIC\_VECTOR **(**15 **downto** 0**);**

LOAD **:** **in** STD\_LOGIC\_VECTOR**(**1 **downto** 0**);**

CLK **:** **in** STD\_LOGIC**;**

Q **:** **out** STD\_LOGIC\_VECTOR**(**15 **downto** 0**)**

**);**

**end** reg16**;**

**architecture** Behavioral **of** reg16 **is**

**begin** **process(**CLK**)**

**begin**

**if(rising\_edge(**CLK**))** **then**

**if** LOAD**(**0**)** **=**'1' and LOAD**(**1**)** **=**'1' **then**

Q**<=**D **after** 1 ns**;**

**end** **if;**

**end** **if;**

**end** **process;**

**end** Behavioral**;**

## Register File with 8 16 bit registers and A and B buses:

**entity** regfile\_16bit **is**

**Port** **(** A\_Sel **:** **in** STD\_LOGIC\_VECTOR**(**2 **downto** 0**);**

B\_Sel **:** **in** STD\_LOGIC\_VECTOR**(**2 **downto** 0**);**

D\_Sel **:** **in** STD\_LOGIC\_VECTOR**(**2 **downto** 0**);**

A\_Data **:** **out** STD\_LOGIC\_VECTOR**(**15 **downto** 0**);**

B\_Data **:** **out** STD\_LOGIC\_VECTOR**(**15 **downto** 0**);**

D\_Data **:** **in** STD\_LOGIC\_VECTOR**(**15 **downto** 0**);**

Load\_En **:** **in** STD\_LOGIC**;**

CLK **:** **in** STD\_LOGIC**);**

**end** regfile\_16bit**;**

**architecture** Behavioral **of** regfile\_16bit **is**

-- Components

-- 16-bit Register

**COMPONENT** reg16

**PORT(** D **:** **in** STD\_LOGIC\_VECTOR **(**15 **downto** 0**);**

LOAD **:** **in** STD\_LOGIC\_VECTOR**(**1 **downto** 0**);**

CLK **:** **in** STD\_LOGIC**;**

Q **:** **out** STD\_LOGIC\_VECTOR**(**15 **downto** 0**)**

**);**

**END** **COMPONENT;**

-- 3 to 8 Decoder

**COMPONENT** decoder\_3to8

**PORT(** A **:** **in** STD\_LOGIC\_VECTOR**(**2 **downto** 0**);**

Q0 **:** **out** STD\_LOGIC**;**

Q1 **:** **out** STD\_LOGIC**;**

Q2 **:** **out** STD\_LOGIC**;**

Q3 **:** **out** STD\_LOGIC**;**

Q4 **:** **out** STD\_LOGIC**;**

Q5 **:** **out** STD\_LOGIC**;**

Q6 **:** **out** STD\_LOGIC**;**

Q7 **:** **out** STD\_LOGIC

**);**

**END** **COMPONENT;**

-- MUX8 16 bit

**COMPONENT** mux8\_16bit

**PORT(**IN0 **:** **in** STD\_LOGIC\_VECTOR **(**15 **downto** 0**);**

IN1 **:** **in** STD\_LOGIC\_VECTOR **(**15 **downto** 0**);**

IN2 **:** **in** STD\_LOGIC\_VECTOR **(**15 **downto** 0**);**

IN3 **:** **in** STD\_LOGIC\_VECTOR **(**15 **downto** 0**);**

IN4 **:** **in** STD\_LOGIC\_VECTOR **(**15 **downto** 0**);**

IN5 **:** **in** STD\_LOGIC\_VECTOR **(**15 **downto** 0**);**

IN6 **:** **in** STD\_LOGIC\_VECTOR **(**15 **downto** 0**);**

IN7 **:** **in** STD\_LOGIC\_VECTOR **(**15 **downto** 0**);**

S **:** **in** STD\_LOGIC\_VECTOR**(**2 **downto** 0**);**

Z **:** **out** STD\_LOGIC\_VECTOR **(**15 **downto** 0**)**

**);**

**END** **COMPONENT;**

**signal** load\_reg0**,** load\_reg1**,** load\_reg2**,** load\_reg3**,** load\_reg4**,** load\_reg5**,** load\_reg6**,** load\_reg7**:** STD\_LOGIC**;**

**signal** reg0\_q**,** reg1\_q**,** reg2\_q**,** reg3\_q**,** reg4\_q**,** reg5\_q**,** reg6\_q**,** reg7\_q**:** STD\_LOGIC\_VECTOR**(**15 **downto** 0**);**

**begin**

-- Port Maps

-- Registers

reg00**:** reg16 **PORT** **MAP(**

D **=>** D\_DATA**,**

LOAD**(**0**)** **=>** load\_reg0**,**

LOAD**(**1**)** **=>** Load\_En**,**

CLK **=>** CLK**,**

Q **=>** reg0\_q

**);**

reg01**:** reg16 **PORT** **MAP(**

D **=>** D\_DATA**,**

LOAD**(**0**)** **=>** load\_reg1**,**

LOAD**(**1**)** **=>** Load\_En**,**

CLK **=>** CLK**,**

Q **=>** reg1\_q

**);**

reg02**:** reg16 **PORT** **MAP(**

D **=>** D\_DATA**,**

LOAD**(**0**)** **=>** load\_reg2**,**

LOAD**(**1**)** **=>** Load\_En**,**

CLK **=>** CLK**,**

Q **=>** reg2\_q

**);**

reg03**:** reg16 **PORT** **MAP(**

D **=>** D\_DATA**,**

LOAD**(**0**)** **=>** load\_reg3**,**

LOAD**(**1**)** **=>** Load\_En**,**

CLK **=>** CLK**,**

Q **=>** reg3\_q

**);**

reg04**:** reg16 **PORT** **MAP(**

D **=>** D\_DATA**,**

LOAD**(**0**)** **=>** load\_reg4**,**

LOAD**(**1**)** **=>** Load\_En**,**

CLK **=>** CLK**,**

Q **=>** reg4\_q

**);**

reg05**:** reg16 **PORT** **MAP(**

D **=>** D\_DATA**,**

LOAD**(**0**)** **=>** load\_reg5**,**

LOAD**(**1**)** **=>** Load\_En**,**

CLK **=>** CLK**,**

Q **=>** reg5\_q

**);**

reg06**:** reg16 **PORT** **MAP(**

D **=>** D\_DATA**,**

LOAD**(**0**)** **=>** load\_reg6**,**

LOAD**(**1**)** **=>** Load\_En**,**

CLK **=>** CLK**,**

Q **=>** reg6\_q

**);**

reg07**:** reg16 **PORT** **MAP(**

D **=>** D\_DATA**,**

LOAD**(**0**)** **=>** load\_reg7**,**

LOAD**(**1**)** **=>** Load\_En**,**

CLK **=>** CLK**,**

Q **=>** reg7\_q

**);**

-------------------------------------------

-- Destination Register Decoder

dest\_decoder\_3to8**:** decoder\_3to8 **PORT** **MAP(**

A**(**0**)** **=>** D\_Sel**(**0**),**

A**(**1**)** **=>** D\_Sel**(**1**),**

A**(**2**)** **=>** D\_Sel**(**2**),**

Q0 **=>** load\_reg0**,**

Q1 **=>** load\_reg1**,**

Q2 **=>** load\_reg2**,**

Q3 **=>** load\_reg3**,**

Q4 **=>** load\_reg4**,**

Q5 **=>** load\_reg5**,**

Q6 **=>** load\_reg6**,**

Q7 **=>** load\_reg7

**);**

---------------------------------------------

-- MUX A

muxA**:** mux8\_16bit **PORT** **MAP(**

IN0 **=>** reg0\_q**,**

IN1 **=>** reg1\_q**,**

IN2 **=>** reg2\_q**,**

IN3 **=>** reg3\_q**,**

IN4 **=>** reg4\_q**,**

IN5 **=>** reg5\_q**,**

IN6 **=>** reg6\_q**,**

IN7 **=>** reg7\_q**,**

S**(**0**)** **=>** A\_Sel**(**0**),**

S**(**1**)** **=>** A\_Sel**(**1**),**

S**(**2**)** **=>** A\_Sel**(**2**),**

Z **=>** A\_Data

**);**

-- MUX B

muxB**:** mux8\_16bit **PORT** **MAP(**

IN0 **=>** reg0\_q**,**

IN1 **=>** reg1\_q**,**

IN2 **=>** reg2\_q**,**

IN3 **=>** reg3\_q**,**

IN4 **=>** reg4\_q**,**

IN5 **=>** reg5\_q**,**

IN6 **=>** reg6\_q**,**

IN7 **=>** reg7\_q**,**

S**(**0**)** **=>** B\_Sel**(**0**),**

S**(**1**)** **=>** B\_Sel**(**1**),**

S**(**2**)** **=>** B\_Sel**(**2**),**

Z **=>** B\_Data

**);**

---------------------------------------------

**end** Behavioral**;**

## Full Adder:

**entity** full\_adder **is**

**Port** **(** X **:** **in** STD\_LOGIC**;**

Y **:** **in** STD\_LOGIC**;**

Cin **:** **in** STD\_LOGIC**;**

Sum **:** **out** STD\_LOGIC**;**

Cout **:** **out** STD\_LOGIC**);**

**end** full\_adder**;**

**architecture** Behavioral **of** full\_adder **is**

**begin**

Sum **<=** X xor Y xor Cin **after** 1ns**;**

Cout **<=** **(**X and Y**)** or **(**Cin and **(**X xor Y**))** **after** 1ns**;**

**end** Behavioral**;**

## Ripple Adder 16 bit:

**entity** ripple\_adder\_16bit **is**

**Port** **(** A **:** **in** STD\_LOGIC\_VECTOR**(**15 **downto** 0**);**

B **:** **in** STD\_LOGIC\_VECTOR**(**15 **downto** 0**);**

Cin **:** **in** STD\_LOGIC**;**

V **:** **out** STD\_LOGIC**;**

Cout **:** **out** STD\_LOGIC**;**

G **:** **out** STD\_LOGIC\_VECTOR**(**15 **downto** 0**));**

**end** ripple\_adder\_16bit**;**

**architecture** Behavioral **of** ripple\_adder\_16bit **is**

-- Components

-- Full Adder

**COMPONENT** full\_adder

**PORT** **(** X **:** **in** STD\_LOGIC**;**

Y **:** **in** STD\_LOGIC**;**

Cin **:** **in** STD\_LOGIC**;**

Sum **:** **out** STD\_LOGIC**;**

Cout **:** **out** STD\_LOGIC

**);**

**END** **COMPONENT;**

**signal** C1**,** C2**,** C3**,** C4**,** C5**,** C6**,** C7**,** C8**,** C9**,** C10**,** C11**,** C12**,** C13**,** C14**,** C15**,** C16**:** STD\_LOGIC**;**

**begin**

-- Port Maps

-- Full Adders

FA0**:** full\_adder **PORT** **MAP(**

X **=>** A**(**0**),**

Y **=>** B**(**0**),**

Cin **=>** Cin**,**

Sum **=>** G**(**0**),**

Cout **=>** C1

**);**

FA1**:** full\_adder **PORT** **MAP(**

X **=>** A**(**1**),**

Y **=>** B**(**1**),**

Cin **=>** C1**,**

Sum **=>** G**(**1**),**

Cout **=>** C2

**);**

FA2**:** full\_adder **PORT** **MAP(**

X **=>** A**(**2**),**

Y **=>** B**(**2**),**

Cin **=>** C2**,**

Sum **=>** G**(**2**),**

Cout **=>** C3

**);**

FA3**:** full\_adder **PORT** **MAP(**

X **=>** A**(**3**),**

Y **=>** B**(**3**),**

Cin **=>** C3**,**

Sum **=>** G**(**3**),**

Cout **=>** C4

**);**

FA4**:** full\_adder **PORT** **MAP(**

X **=>** A**(**4**),**

Y **=>** B**(**4**),**

Cin **=>** C4**,**

Sum **=>** G**(**4**),**

Cout **=>** C5

**);**

FA5**:** full\_adder **PORT** **MAP(**

X **=>** A**(**5**),**

Y **=>** B**(**5**),**

Cin **=>** C5**,**

Sum **=>** G**(**5**),**

Cout **=>** C6

**);**

FA6**:** full\_adder **PORT** **MAP(**

X **=>** A**(**6**),**

Y **=>** B**(**6**),**

Cin **=>** C6**,**

Sum **=>** G**(**6**),**

Cout **=>** C7

**);**

FA7**:** full\_adder **PORT** **MAP(**

X **=>** A**(**7**),**

Y **=>** B**(**7**),**

Cin **=>** C7**,**

Sum **=>** G**(**7**),**

Cout **=>** C8

**);**

FA8**:** full\_adder **PORT** **MAP(**

X **=>** A**(**8**),**

Y **=>** B**(**8**),**

Cin **=>** C8**,**

Sum **=>** G**(**8**),**

Cout **=>** C9

**);**

FA9**:** full\_adder **PORT** **MAP(**

X **=>** A**(**9**),**

Y **=>** B**(**9**),**

Cin **=>** C9**,**

Sum **=>** G**(**9**),**

Cout **=>** C10

**);**

FA10**:** full\_adder **PORT** **MAP(**

X **=>** A**(**10**),**

Y **=>** B**(**10**),**

Cin **=>** C10**,**

Sum **=>** G**(**10**),**

Cout **=>** C11

**);**

FA11**:** full\_adder **PORT** **MAP(**

X **=>** A**(**11**),**

Y **=>** B**(**11**),**

Cin **=>** C11**,**

Sum **=>** G**(**11**),**

Cout **=>** C12

**);**

FA12**:** full\_adder **PORT** **MAP(**

X **=>** A**(**12**),**

Y **=>** B**(**12**),**

Cin **=>** C12**,**

Sum **=>** G**(**12**),**

Cout **=>** C13

**);**

FA13**:** full\_adder **PORT** **MAP(**

X **=>** A**(**13**),**

Y **=>** B**(**13**),**

Cin **=>** C13**,**

Sum **=>** G**(**13**),**

Cout **=>** C14

**);**

FA14**:** full\_adder **PORT** **MAP(**

X **=>** A**(**14**),**

Y **=>** B**(**14**),**

Cin **=>** C14**,**

Sum **=>** G**(**14**),**

Cout **=>** C15

**);**

FA15**:** full\_adder **PORT** **MAP(**

X **=>** A**(**15**),**

Y **=>** B**(**15**),**

Cin **=>** C15**,**

Sum **=>** G**(**15**),**

Cout **=>** C16

**);**

Cout **<=** C16**;**

V **<=** **(**C16 xor C15**);**

**end** Behavioral**;**

## B Input Logic:

**entity** b\_input\_logic **is**

**Port** **(** B **:** **in** STD\_LOGIC\_VECTOR**(**15 **downto** 0**);**

S **:** **in** STD\_LOGIC\_VECTOR**(**1 **downto** 0**);**

Y **:** **out** STD\_LOGIC\_VECTOR**(**15 **downto** 0**));**

**end** b\_input\_logic**;**

**architecture** Behavioral **of** b\_input\_logic **is**

**begin**

Y**(**0**)** **<=** **(**B**(**0**)** and S**(**0**))** or **(**not B**(**0**)** and S**(**1**))** **after** 1ns**;**

Y**(**1**)** **<=** **(**B**(**1**)** and S**(**0**))** or **(**not B**(**1**)** and S**(**1**))** **after** 1ns**;**

Y**(**2**)** **<=** **(**B**(**2**)** and S**(**0**))** or **(**not B**(**2**)** and S**(**1**))** **after** 1ns**;**

Y**(**3**)** **<=** **(**B**(**3**)** and S**(**0**))** or **(**not B**(**3**)** and S**(**1**))** **after** 1ns**;**

Y**(**4**)** **<=** **(**B**(**4**)** and S**(**0**))** or **(**not B**(**4**)** and S**(**1**))** **after** 1ns**;**

Y**(**5**)** **<=** **(**B**(**5**)** and S**(**0**))** or **(**not B**(**5**)** and S**(**1**))** **after** 1ns**;**

Y**(**6**)** **<=** **(**B**(**6**)** and S**(**0**))** or **(**not B**(**6**)** and S**(**1**))** **after** 1ns**;**

Y**(**7**)** **<=** **(**B**(**7**)** and S**(**0**))** or **(**not B**(**7**)** and S**(**1**))** **after** 1ns**;**

Y**(**8**)** **<=** **(**B**(**8**)** and S**(**0**))** or **(**not B**(**8**)** and S**(**1**))** **after** 1ns**;**

Y**(**9**)** **<=** **(**B**(**9**)** and S**(**0**))** or **(**not B**(**9**)** and S**(**1**))** **after** 1ns**;**

Y**(**10**)** **<=** **(**B**(**10**)** and S**(**0**))** or **(**not B**(**10**)** and S**(**1**))** **after** 1ns**;**

Y**(**11**)** **<=** **(**B**(**11**)** and S**(**0**))** or **(**not B**(**11**)** and S**(**1**))** **after** 1ns**;**

Y**(**12**)** **<=** **(**B**(**12**)** and S**(**0**))** or **(**not B**(**12**)** and S**(**1**))** **after** 1ns**;**

Y**(**13**)** **<=** **(**B**(**13**)** and S**(**0**))** or **(**not B**(**13**)** and S**(**1**))** **after** 1ns**;**

Y**(**14**)** **<=** **(**B**(**14**)** and S**(**0**))** or **(**not B**(**14**)** and S**(**1**))** **after** 1ns**;**

Y**(**15**)** **<=** **(**B**(**15**)** and S**(**0**))** or **(**not B**(**15**)** and S**(**1**))** **after** 1ns**;**

**end** Behavioral**;**

## Arithmetic Unit:

**entity** arithmetic\_unit **is**

**Port** **(** A **:** **in** STD\_LOGIC\_VECTOR**(**15 **downto** 0**);**

B **:** **in** STD\_LOGIC\_VECTOR**(**15 **downto** 0**);**

Cin **:** **in** STD\_LOGIC**;**

SelB **:** **in** STD\_LOGIC\_VECTOR**(**1 **downto** 0**);**

G **:** **out** STD\_LOGIC\_VECTOR**(**15 **downto** 0**);**

Cout **:** **out** STD\_LOGIC**;**

V **:** **out** STD\_LOGIC**);**

**end** arithmetic\_unit**;**

**architecture** Behavioral **of** arithmetic\_unit **is**

-- Components

-- B Input Logic

**COMPONENT** b\_input\_logic

**PORT** **(** B **:** **in** STD\_LOGIC\_VECTOR**(**15 **downto** 0**);**

S **:** **in** STD\_LOGIC\_VECTOR**(**1 **downto** 0**);**

Y **:** **out** STD\_LOGIC\_VECTOR**(**15 **downto** 0**));**

**END** **COMPONENT;**

-- 16 bit Ripple Adder

**COMPONENT** ripple\_adder\_16bit

**PORT** **(** A **:** **in** STD\_LOGIC\_VECTOR**(**15 **downto** 0**);**

B **:** **in** STD\_LOGIC\_VECTOR**(**15 **downto** 0**);**

Cin **:** **in** STD\_LOGIC**;**

V **:** **out** STD\_LOGIC**;**

Cout **:** **out** STD\_LOGIC**;**

G **:** **out** STD\_LOGIC\_VECTOR**(**15 **downto** 0**));**

**END** **COMPONENT;**

**signal** blogic\_to\_adder**,** adder\_to\_G\_output**:** STD\_LOGIC\_VECTOR**(**15 **downto** 0**);**

**begin**

-- Port Maps

-- B Logic

BLOGIC**:** b\_input\_logic **PORT** **MAP(**

B **=>** B**,**

S **=>** SelB**,**

Y **=>** blogic\_to\_adder

**);**

-- Ripple Adder

RA**:** ripple\_adder\_16bit **PORT** **MAP(**

A **=>** A**,**

B **=>** blogic\_to\_adder**,**

Cin **=>** Cin**,**

V **=>** V**,**

Cout **=>** Cout**,**

G **=>** adder\_to\_G\_output

**);**

G **<=** adder\_to\_G\_output **after** 2ns**;**

**end** Behavioral**;**

## Logic Unit:

**entity** logic\_unit **is**

**Port** **(** A **:** **in** STD\_LOGIC\_VECTOR**(**15 **downto** 0**);**

B **:** **in** STD\_LOGIC\_VECTOR**(**15 **downto** 0**);**

S **:** **in** STD\_LOGIC\_VECTOR**(**1 **downto** 0**);**

G **:** **out** STD\_LOGIC\_VECTOR**(**15 **downto** 0**));**

**end** logic\_unit**;**

**architecture** Behavioral **of** logic\_unit **is**

-- Components

-- MUX 4 to 1

**COMPONENT** mux4\_16bit

**PORT(** IN0 **:** **in** STD\_LOGIC\_VECTOR**(**15 **downto** 0**);**

IN1 **:** **in** STD\_LOGIC\_VECTOR**(**15 **downto** 0**);**

IN2 **:** **in** STD\_LOGIC\_VECTOR**(**15 **downto** 0**);**

IN3 **:** **in** STD\_LOGIC\_VECTOR**(**15 **downto** 0**);**

S **:** **in** STD\_LOGIC\_VECTOR**(**1 **downto** 0**);**

Z **:** **out** STD\_LOGIC\_VECTOR**(**15 **downto** 0**));**

**END** **COMPONENT;**

**signal** AandB**,** AorB**,** AxorB**,** notA**:** STD\_LOGIC\_VECTOR**(**15 **downto** 0**);**

**begin**

-- Port maps

-- signals

AandB **<=** A and B**;**

AorB **<=** A or B**;**

AxorB **<=** A xor B**;**

notA **<=** not A**;**

-- MUX

MUX**:** mux4\_16bit **PORT** **MAP(**

IN0 **=>** AandB**,**

IN1 **=>** AorB**,**

IN2 **=>** AxorB**,**

IN3 **=>** notA**,**

S **=>** S**,**

Z **=>** G

**);**

**end** Behavioral**;**

## ALU:

**entity** alu\_16bit **is**

**Port** **(** A **:** **in** STD\_LOGIC\_VECTOR**(**15 **downto** 0**);**

B **:** **in** STD\_LOGIC\_VECTOR**(**15 **downto** 0**);**

GSel **:** **in** STD\_LOGIC\_VECTOR**(**3 **downto** 0**);**

C **:** **out** STD\_LOGIC**;**

V **:** **out** STD\_LOGIC**;**

G **:** **out** STD\_LOGIC\_VECTOR**(**15 **downto** 0**));**

**end** alu\_16bit**;**

**architecture** Behavioral **of** alu\_16bit **is**

-- Components

-- Arithmetic Circuit

**COMPONENT** arithmetic\_unit

**PORT(**A **:** **in** STD\_LOGIC\_VECTOR**(**15 **downto** 0**);**

B **:** **in** STD\_LOGIC\_VECTOR**(**15 **downto** 0**);**

Cin **:** **in** STD\_LOGIC**;**

SelB **:** **in** STD\_LOGIC\_VECTOR**(**1 **downto** 0**);**

G **:** **out** STD\_LOGIC\_VECTOR**(**15 **downto** 0**);**

Cout **:** **out** STD\_LOGIC**;**

V **:** **out** STD\_LOGIC**);**

**END** **COMPONENT;**

-- Logic Circuit

**COMPONENT** logic\_unit

**PORT(**A **:** **in** STD\_LOGIC\_VECTOR**(**15 **downto** 0**);**

B **:** **in** STD\_LOGIC\_VECTOR**(**15 **downto** 0**);**

S **:** **in** STD\_LOGIC\_VECTOR**(**1 **downto** 0**);**

G **:** **out** STD\_LOGIC\_VECTOR**(**15 **downto** 0**));**

**END** **COMPONENT;**

-- Select Arithmetic or Logic MUX

**COMPONENT** mux2\_16bit

**PORT(**S **:** **in** STD\_LOGIC**;**

IN0 **:** **in** STD\_LOGIC\_VECTOR **(**15 **downto** 0**);**

IN1 **:** **in** STD\_LOGIC\_VECTOR **(**15 **downto** 0**);**

Z **:** **out** STD\_LOGIC\_VECTOR **(**15 **downto** 0**));**

**END** **COMPONENT;**

**signal** Cin**,** C\_out**,** V\_out**:** STD\_LOGIC**;**

**signal** FSel**:** STD\_LOGIC\_VECTOR**(**2 **downto** 0**);**

**signal** AUtoMUX**,** LUtoMUX**:** STD\_LOGIC\_VECTOR**(**15 **downto** 0**);**

**begin**

-- Port Maps

-- Signals

Cin **<=** GSel**(**0**);**

FSel **<=** GSel**(**3 **downto** 1**);**

-- Arithmetic Unit

AU**:** arithmetic\_unit **PORT** **MAP(**

A **=>** A**,**

B **=>** B**,**

Cin **=>** Cin**,**

SelB**(**0**)** **=>** FSel**(**0**),**

SelB**(**1**)** **=>** FSel**(**1**),**

G **=>** AUtoMUX**,**

Cout **=>** C\_out**,**

V **=>** V\_out**);**

-- Logic Unit

LUL**:** logic\_unit **PORT** **MAP(**

A **=>** A**,**

B **=>** B**,**

S**(**0**)** **=>** FSel**(**0**),**

S**(**1**)** **=>** FSel**(**1**),**

G **=>** LUtoMUX **);**

-- MUX

ALUMUX**:** mux2\_16bit **PORT** **MAP(**

S **=>** FSel**(**2**),**

IN0 **=>** AUtoMUX**,**

IN1 **=>** LUtoMUX**,**

Z **=>** G **);**

-- Control Flags

C **<=** C\_out **when** FSel**(**2**)** **=** '0' **else**

'0'**;**

V **<=** V\_out **when** FSel**(**2**)** **=** '0' **else**

'0'**;**

**end** Behavioral**;**

## Shifter:

**entity** shifter\_16bit **is**

**Port** **(** B **:** **in** STD\_LOGIC\_VECTOR**(**15 **downto** 0**);**

S **:** **in** STD\_LOGIC\_VECTOR**(**1 **downto** 0**);**

IR **:** **in** STD\_LOGIC**;**

IL **:** **in** STD\_LOGIC**;**

H **:** **out** STD\_LOGIC\_VECTOR**(**15 **downto** 0**));**

**end** shifter\_16bit**;**

**architecture** Behavioral **of** shifter\_16bit **is**

-- Components

-- MUX3

**COMPONENT** mux3\_1bit

**PORT(**IN0 **:** **in** STD\_LOGIC**;**

IN1 **:** **in** STD\_LOGIC**;**

IN2 **:** **in** STD\_LOGIC**;**

S **:** **in** STD\_LOGIC\_VECTOR**(**1 **downto** 0**);**

Z **:** **out** STD\_LOGIC**);**

**END** **COMPONENT;**

**begin**

-- Port Maps

--MUX0

MUX0**:** mux3\_1bit

**PORT** **MAP(**IN0 **=>** B**(**0**),**

IN1 **=>** B**(**1**),**

IN2 **=>** IL**,**

S **=>** S**,**

Z **=>** H**(**0**));**

--MUX1

MUX1**:** mux3\_1bit

**PORT** **MAP(**IN0 **=>** B**(**1**),**

IN1 **=>** B**(**2**),**

IN2 **=>** B**(**0**),**

S **=>** S**,**

Z **=>** H**(**1**));**

--MUX2

MUX2**:** mux3\_1bit

**PORT** **MAP(**IN0 **=>** B**(**2**),**

IN1 **=>** B**(**3**),**

IN2 **=>** B**(**1**),**

S **=>** S**,**

Z **=>** H**(**2**));**

--MUX3

MUX3**:** mux3\_1bit

**PORT** **MAP(**IN0 **=>** B**(**3**),**

IN1 **=>** B**(**4**),**

IN2 **=>** B**(**2**),**

S **=>** S**,**

Z **=>** H**(**3**));**

--MUX4

MUX4**:** mux3\_1bit

**PORT** **MAP(**IN0 **=>** B**(**4**),**

IN1 **=>** B**(**5**),**

IN2 **=>** B**(**3**),**

S **=>** S**,**

Z **=>** H**(**4**));**

--MUX5

MUX5**:** mux3\_1bit

**PORT** **MAP(**IN0 **=>** B**(**5**),**

IN1 **=>** B**(**6**),**

IN2 **=>** B**(**4**),**

S **=>** S**,**

Z **=>** H**(**5**));**

--MUX6

MUX6**:** mux3\_1bit

**PORT** **MAP(**IN0 **=>** B**(**6**),**

IN1 **=>** B**(**7**),**

IN2 **=>** B**(**5**),**

S **=>** S**,**

Z **=>** H**(**6**));**

--MUX7

MUX7**:** mux3\_1bit

**PORT** **MAP(**IN0 **=>** B**(**7**),**

IN1 **=>** B**(**8**),**

IN2 **=>** B**(**6**),**

S **=>** S**,**

Z **=>** H**(**7**));**

--MUX8

MUX8**:** mux3\_1bit

**PORT** **MAP(**IN0 **=>** B**(**8**),**

IN1 **=>** B**(**9**),**

IN2 **=>** B**(**7**),**

S **=>** S**,**

Z **=>** H**(**8**));**

--MUX9

MUX9**:** mux3\_1bit

**PORT** **MAP(**IN0 **=>** B**(**9**),**

IN1 **=>** B**(**10**),**

IN2 **=>** B**(**8**),**

S **=>** S**,**

Z **=>** H**(**9**));**

--MUX10

MUX10**:** mux3\_1bit

**PORT** **MAP(**IN0 **=>** B**(**10**),**

IN1 **=>** B**(**11**),**

IN2 **=>** B**(**9**),**

S **=>** S**,**

Z **=>** H**(**10**));**

--MUX11

MUX11**:** mux3\_1bit

**PORT** **MAP(**IN0 **=>** B**(**11**),**

IN1 **=>** B**(**12**),**

IN2 **=>** B**(**10**),**

S **=>** S**,**

Z **=>** H**(**11**));**

--MUX12

MUX12**:** mux3\_1bit

**PORT** **MAP(**IN0 **=>** B**(**12**),**

IN1 **=>** B**(**13**),**

IN2 **=>** B**(**11**),**

S **=>** S**,**

Z **=>** H**(**12**));**

--MUX13

MUX13**:** mux3\_1bit

**PORT** **MAP(**IN0 **=>** B**(**13**),**

IN1 **=>** B**(**14**),**

IN2 **=>** B**(**12**),**

S **=>** S**,**

Z **=>** H**(**13**));**

--MUX14

MUX14**:** mux3\_1bit

**PORT** **MAP(**IN0 **=>** B**(**14**),**

IN1 **=>** B**(**15**),**

IN2 **=>** B**(**13**),**

S **=>** S**,**

Z **=>** H**(**14**));**

--MUX15

MUX15**:** mux3\_1bit

**PORT** **MAP(**IN0 **=>** B**(**15**),**

IN1 **=>** IR**,**

IN2 **=>** B**(**14**),**

S **=>** S**,**

Z **=>** H**(**15**));**

**end** Behavioral**;**

## Function Unit:

**entity** function\_unit **is**

**Port** **(** A **:** **in** STD\_LOGIC\_VECTOR**(**15 **downto** 0**);**

B **:** **in** STD\_LOGIC\_VECTOR**(**15 **downto** 0**);**

FSel **:** **in** STD\_LOGIC\_VECTOR**(**4 **downto** 0**);**

C **:** **out** STD\_LOGIC**;**

V **:** **out** STD\_LOGIC**;**

N **:** **out** STD\_LOGIC**;**

Z **:** **out** STD\_LOGIC**;**

F **:** **out** STD\_LOGIC\_VECTOR**(**15 **downto** 0**));**

**end** function\_unit**;**

**architecture** Behavioral **of** function\_unit **is**

-- Components

-- ALU

**COMPONENT** alu\_16bit

**PORT(**A **:** **in** STD\_LOGIC\_VECTOR**(**15 **downto** 0**);**

B **:** **in** STD\_LOGIC\_VECTOR**(**15 **downto** 0**);**

GSel **:** **in** STD\_LOGIC\_VECTOR**(**3 **downto** 0**);**

C **:** **out** STD\_LOGIC**;**

V **:** **out** STD\_LOGIC**;**

G **:** **out** STD\_LOGIC\_VECTOR**(**15 **downto** 0**));**

**END** **COMPONENT;**

-- Shifter

**COMPONENT** shifter\_16bit

**PORT(**B **:** **in** STD\_LOGIC\_VECTOR**(**15 **downto** 0**);**

S **:** **in** STD\_LOGIC\_VECTOR**(**1 **downto** 0**);**

IR **:** **in** STD\_LOGIC**;**

IL **:** **in** STD\_LOGIC**;**

H **:** **out** STD\_LOGIC\_VECTOR**(**15 **downto** 0**));**

**END** **COMPONENT;**

-- MUX2

**COMPONENT** mux2\_16bit

**PORT(**IN0 **:** **in** STD\_LOGIC\_VECTOR**(**15 **downto** 0**);**

IN1 **:** **in** STD\_LOGIC\_VECTOR**(**15 **downto** 0**);**

S **:** **in** STD\_LOGIC**;**

Z **:** **out** STD\_LOGIC\_VECTOR**(**15 **downto** 0**));**

**END** **COMPONENT;**

**signal** outputALU**,** outputShifter**,** muxFOUT**:** STD\_LOGIC\_VECTOR**(**15 **downto** 0**);**

**begin**

-- Port Maps

-- ALU

ALU**:** alu\_16bit

**PORT** **MAP(**A **=>** A**,**

B **=>** B**,**

GSel **=>** FSel**(**3 **downto** 0**),**

C **=>** C**,**

V **=>** V**,**

G **=>** outputALU**);**

-- Shifter

SHIFTER**:** shifter\_16bit

**PORT** **MAP(**B **=>** B**,**

S **=>** FSel**(**3 **downto** 2**),**

IR **=>** '0'**,**

IL **=>** '0'**,**

H **=>** outputShifter**);**

-- MUXF

MUXF**:** mux2\_16bit

**PORT** **MAP(**IN0 **=>** outputALU**,**

IN1 **=>** outputShifter**,**

S **=>** FSel**(**4**),**

Z **=>** muxFOUT**);**

Z **<=** '1' **when** muxFOUT **=** x"0000" **else**

'0'**;**

N **<=** '1' **when** muxFOUT**(**15**)** **=** '1' **else**

'0'**;**

F **<=** muxFOUT**;**

**end** Behavioral**;**

## Datapath:

**entity** datapath\_16bit **is**

**Port** **(** CONTROL\_WORD **:** **in** STD\_LOGIC\_VECTOR**(**16 **downto** 0**);**

CONST\_IN **:** **in** STD\_LOGIC\_VECTOR**(**15 **downto** 0**);**

DATA\_IN **:** **in** STD\_LOGIC\_VECTOR**(**15 **downto** 0**);**

CLK **:** **in** STD\_LOGIC**;**

ADDR\_OUT **:** **out** STD\_LOGIC\_VECTOR**(**15 **downto** 0**);**

DATA\_OUT **:** **out** STD\_LOGIC\_VECTOR**(**15 **downto** 0**);**

C **:** **out** STD\_LOGIC**;**

V **:** **out** STD\_LOGIC**;**

N **:** **out** STD\_LOGIC**;**

Z **:** **out** STD\_LOGIC**);**

**end** datapath\_16bit**;**

**architecture** Behavioral **of** datapath\_16bit **is**

-- Components

-- Regfile

**COMPONENT** regfile\_16bit

**PORT(**A\_Sel **:** **in** STD\_LOGIC\_VECTOR**(**2 **downto** 0**);**

B\_Sel **:** **in** STD\_LOGIC\_VECTOR**(**2 **downto** 0**);**

D\_Sel **:** **in** STD\_LOGIC\_VECTOR**(**2 **downto** 0**);**

A\_Data **:** **out** STD\_LOGIC\_VECTOR**(**15 **downto** 0**);**

B\_Data **:** **out** STD\_LOGIC\_VECTOR**(**15 **downto** 0**);**

D\_Data **:** **in** STD\_LOGIC\_VECTOR**(**15 **downto** 0**);**

Load\_En **:** **in** STD\_LOGIC**;**

CLK **:** **in** STD\_LOGIC**);**

**END** **COMPONENT;**

-- Function Unit

**COMPONENT** function\_unit

**PORT(**A **:** **in** STD\_LOGIC\_VECTOR**(**15 **downto** 0**);**

B **:** **in** STD\_LOGIC\_VECTOR**(**15 **downto** 0**);**

FSel **:** **in** STD\_LOGIC\_VECTOR**(**4 **downto** 0**);**

C **:** **out** STD\_LOGIC**;**

V **:** **out** STD\_LOGIC**;**

N **:** **out** STD\_LOGIC**;**

Z **:** **out** STD\_LOGIC**;**

F **:** **out** STD\_LOGIC\_VECTOR**(**15 **downto** 0**));**

**END** **COMPONENT;**

-- Mux2

**COMPONENT** mux2\_16bit

**PORT(**IN0 **:** **in** STD\_LOGIC\_VECTOR**(**15 **downto** 0**);**

IN1 **:** **in** STD\_LOGIC\_VECTOR**(**15 **downto** 0**);**

S **:** **in** STD\_LOGIC**;**

Z **:** **out** STD\_LOGIC\_VECTOR**(**15 **downto** 0**));**

**END** **COMPONENT;**

**signal** B\_regfile\_muxB**,** muxB\_out**,** A\_regfile\_function\_unit**,** function\_unit\_out**,** muxD\_out**:** STD\_LOGIC\_VECTOR**(**15 **downto** 0**);**

**begin**

-- Port Maps

-- MUXB

MUXB**:** mux2\_16bit

**PORT** **MAP(**IN0 **=>** B\_regfile\_muxB**,**

IN1 **=>** CONST\_IN**,**

S **=>** CONTROL\_WORD**(**7**),**

Z **=>** muxB\_out**);**

--MUXD

MUXD**:** mux2\_16bit

**PORT** **MAP(**IN0 **=>** function\_unit\_out**,**

IN1 **=>** DATA\_IN**,**

S **=>** CONTROL\_WORD**(**1**),**

Z **=>** muxD\_out**);**

-- Regfile

REGFILE**:** regfile\_16bit

**PORT** **MAP(**A\_Sel **=>** CONTROL\_WORD**(**13 **downto** 11**),**

B\_Sel **=>** CONTROL\_WORD**(**10 **downto** 8**),**

D\_Sel **=>** CONTROL\_WORD**(**16 **downto** 14**),**

A\_Data **=>** A\_regfile\_function\_unit**,**

B\_Data **=>** B\_regfile\_muxB**,**

D\_Data **=>** muxD\_out**,**

Load\_En **=>** CONTROL\_WORD**(**0**),**

CLK **=>** CLK**);**

-- Function Unit

FUNC\_UNIT**:** function\_unit

**PORT** **MAP(**A **=>** A\_regfile\_function\_unit**,**

B **=>** muxB\_out**,**

FSel **=>** CONTROL\_WORD**(**6 **downto** 2**),**

C **=>** C**,**

V **=>** V**,**

N **=>** N**,**

Z **=>** Z**,**

F **=>** function\_unit\_out**);**

-- Signals

ADDR\_OUT **<=** A\_regfile\_function\_unit**;**

DATA\_OUT **<=** muxB\_out**;**

**end** Behavioral**;**

# VHDL Test Benches:

This section shows the code used to test the functionality of all of the components of the datapath including the datapath itself.

## Decoder 3 to 8:

Cycles through all the possible input permutations of the 3to8 decoder.

**ENTITY** decoder\_3to8\_tb **IS**

**END** decoder\_3to8\_tb**;**

**ARCHITECTURE** behavior **OF** decoder\_3to8\_tb **IS**

-- Component Declaration for the Unit Under Test (UUT)

**COMPONENT** decoder\_3to8

**PORT(**

A0 **:** **IN** std\_logic**;**

A1 **:** **IN** std\_logic**;**

A2 **:** **IN** std\_logic**;**

Q0 **:** **OUT** std\_logic**;**

Q1 **:** **OUT** std\_logic**;**

Q2 **:** **OUT** std\_logic**;**

Q3 **:** **OUT** std\_logic**;**

Q4 **:** **OUT** std\_logic**;**

Q5 **:** **OUT** std\_logic**;**

Q6 **:** **OUT** std\_logic**;**

Q7 **:** **OUT** std\_logic

**);**

**END** **COMPONENT;**

--Inputs

**signal** A0 **:** std\_logic **:=** '0'**;**

**signal** A1 **:** std\_logic **:=** '0'**;**

**signal** A2 **:** std\_logic **:=** '0'**;**

--Outputs

**signal** Q0 **:** std\_logic**;**

**signal** Q1 **:** std\_logic**;**

**signal** Q2 **:** std\_logic**;**

**signal** Q3 **:** std\_logic**;**

**signal** Q4 **:** std\_logic**;**

**signal** Q5 **:** std\_logic**;**

**signal** Q6 **:** std\_logic**;**

**signal** Q7 **:** std\_logic**;**

**BEGIN**

-- Instantiate the Unit Under Test (UUT)

uut**:** decoder\_3to8 **PORT** **MAP** **(**

A0 **=>** A0**,**

A1 **=>** A1**,**

A2 **=>** A2**,**

Q0 **=>** Q0**,**

Q1 **=>** Q1**,**

Q2 **=>** Q2**,**

Q3 **=>** Q3**,**

Q4 **=>** Q4**,**

Q5 **=>** Q5**,**

Q6 **=>** Q6**,**

Q7 **=>** Q7

**);**

-- Not a clocked component

-- Stimulus process

stim\_proc**:** **process**

**begin**

**wait** **for** 10ns**;**

A0 **<=** '0'**;**

A1 **<=** '0'**;**

A2 **<=** '0'**;**

**wait** **for** 10ns**;**

A0 **<=** '1'**;**

A1 **<=** '0'**;**

A2 **<=** '0'**;**

**wait** **for** 10ns**;**

A0 **<=** '0'**;**

A1 **<=** '1'**;**

A2 **<=** '0'**;**

**wait** **for** 10ns**;**

A0 **<=** '1'**;**

A1 **<=** '1'**;**

A2 **<=** '0'**;**

**wait** **for** 10ns**;**

A0 **<=** '0'**;**

A1 **<=** '0'**;**

A2 **<=** '1'**;**

**wait** **for** 10ns**;**

A0 **<=** '1'**;**

A1 **<=** '0'**;**

A2 **<=** '1'**;**

**wait** **for** 10ns**;**

A0 **<=** '0'**;**

A1 **<=** '1'**;**

A2 **<=** '1'**;**

**wait** **for** 10ns**;**

A0 **<=** '1'**;**

A1 **<=** '1'**;**

A2 **<=** '1'**;**

**end** **process;**

**END;**

## Mux 2 16 bit:

Cycles through putting 0xFFFF and 0xAAAA on the output.

ENTITY mux2\_16bit\_tb IS

END mux2\_16bit\_tb;

ARCHITECTURE behavior OF mux2\_16bit\_tb IS

-- Component Declaration for the Unit Under Test (UUT)

COMPONENT mux2\_16bit

PORT(

s : IN std\_logic;

ln0 : IN std\_logic\_vector(15 downto 0);

ln1 : IN std\_logic\_vector(15 downto 0);

Z : OUT std\_logic\_vector(15 downto 0)

);

END COMPONENT;

--Inputs

signal s : std\_logic := '0';

signal ln0 : std\_logic\_vector(15 downto 0) := (others => '0');

signal ln1 : std\_logic\_vector(15 downto 0) := (others => '0');

--Outputs

signal Z : std\_logic\_vector(15 downto 0);

BEGIN

-- Instantiate the Unit Under Test (UUT)

uut: mux2\_16bit PORT MAP (

s => s,

ln0 => ln0,

ln1 => ln1,

Z => Z

);

-- Stimulus process

stim\_proc: process

begin

wait for 10ns;

ln0 <= x"FFFF";

ln1 <= x"AAAA";

wait for 10ns;

s <= '0';

wait for 10ns;

s <= '1';

end process;

END;

## Mux 3 1 bit:

Cycles through ‘1’, ‘0’, ‘1’ on the output.

**ENTITY** mux3\_1bit\_tb **IS**

**END** mux3\_1bit\_tb**;**

**ARCHITECTURE** behavior **OF** mux3\_1bit\_tb **IS**

-- Component Declaration for the Unit Under Test (UUT)

**COMPONENT** mux3\_1bit

**PORT(**

IN0 **:** **IN** std\_logic**;**

IN1 **:** **IN** std\_logic**;**

IN2 **:** **IN** std\_logic**;**

S **:** **IN** std\_logic\_vector**(**1 **downto** 0**);**

Z **:** **OUT** std\_logic

**);**

**END** **COMPONENT;**

--Inputs

**signal** IN0 **:** std\_logic **:=** '0'**;**

**signal** IN1 **:** std\_logic **:=** '0'**;**

**signal** IN2 **:** std\_logic **:=** '0'**;**

**signal** S **:** std\_logic\_vector**(**1 **downto** 0**)** **:=** **(others** **=>** '0'**);**

--Outputs

**signal** Z **:** std\_logic**;**

**BEGIN**

-- Instantiate the Unit Under Test (UUT)

uut**:** mux3\_1bit **PORT** **MAP** **(**

IN0 **=>** IN0**,**

IN1 **=>** IN1**,**

IN2 **=>** IN2**,**

S **=>** S**,**

Z **=>** Z

**);**

-- Stimulus process

stim\_proc**:** **process**

**begin**

IN0 **<=** '1'**;**

IN1 **<=** '0'**;**

IN2 **<=** '1'**;**

S**(**0**)** **<=** '0'**;**

S**(**1**)** **<=** '0'**;**

**wait** **for** 10ns**;**

S**(**0**)** **<=** '1'**;**

S**(**1**)** **<=** '0'**;**

**wait** **for** 10ns**;**

S**(**0**)** **<=** '0'**;**

S**(**1**)** **<=** '1'**;**

**wait** **for** 10ns**;**

S**(**0**)** **<=** '1'**;**

S**(**1**)** **<=** '1'**;**

**wait** **for** 10ns**;**

**end** **process;**

**END;**

## Mux 8 16 bit:

Cycles through putting 0xFFFF, 0xEEEE down to 0x8888 on the output.

ENTITY mux8\_16bit\_tb IS

END mux8\_16bit\_tb;

ARCHITECTURE behavior OF mux8\_16bit\_tb IS

-- Component Declaration for the Unit Under Test (UUT)

COMPONENT mux8\_16bit

PORT(

ln0 : IN std\_logic\_vector(15 downto 0);

ln1 : IN std\_logic\_vector(15 downto 0);

ln2 : IN std\_logic\_vector(15 downto 0);

ln3 : IN std\_logic\_vector(15 downto 0);

ln4 : IN std\_logic\_vector(15 downto 0);

ln5 : IN std\_logic\_vector(15 downto 0);

ln6 : IN std\_logic\_vector(15 downto 0);

ln7 : IN std\_logic\_vector(15 downto 0);

S0 : IN std\_logic;

S1 : IN std\_logic;

S2 : IN std\_logic;

Z : OUT std\_logic\_vector(15 downto 0)

);

END COMPONENT;

--Inputs

signal ln0 : std\_logic\_vector(15 downto 0) := (others => '0');

signal ln1 : std\_logic\_vector(15 downto 0) := (others => '0');

signal ln2 : std\_logic\_vector(15 downto 0) := (others => '0');

signal ln3 : std\_logic\_vector(15 downto 0) := (others => '0');

signal ln4 : std\_logic\_vector(15 downto 0) := (others => '0');

signal ln5 : std\_logic\_vector(15 downto 0) := (others => '0');

signal ln6 : std\_logic\_vector(15 downto 0) := (others => '0');

signal ln7 : std\_logic\_vector(15 downto 0) := (others => '0');

signal S0 : std\_logic := '0';

signal S1 : std\_logic := '0';

signal S2 : std\_logic := '0';

--Outputs

signal Z : std\_logic\_vector(15 downto 0);

-- No clocks detected in port list. Replace <clock> below with

-- appropriate port name

BEGIN

-- Instantiate the Unit Under Test (UUT)

uut: mux8\_16bit PORT MAP (

ln0 => ln0,

ln1 => ln1,

ln2 => ln2,

ln3 => ln3,

ln4 => ln4,

ln5 => ln5,

ln6 => ln6,

ln7 => ln7,

S0 => S0,

S1 => S1,

S2 => S2,

Z => Z

);

-- Stimulus process

stim\_proc: process

begin

ln0 <= x"FFFF";

ln1 <= x"EEEE";

ln2 <= x"DDDD";

ln3 <= x"CCCC";

ln4 <= x"BBBB";

ln5 <= x"AAAA";

ln6 <= x"9999";

ln7 <= x"8888";

wait for 10ns;

S0 <= '0';

S1 <= '0';

S2 <= '0';

wait for 10ns;

S0 <= '1';

S1 <= '0';

S2 <= '0';

wait for 10ns;

S0 <= '0';

S1 <= '1';

S2 <= '0';

wait for 10ns;

S0 <= '1';

S1 <= '1';

S2 <= '0';

wait for 10ns;

S0 <= '0';

S1 <= '0';

S2 <= '1';

wait for 10ns;

S0 <= '1';

S1 <= '0';

S2 <= '1';

wait for 10ns;

S0 <= '0';

S1 <= '1';

S2 <= '1';

wait for 10ns;

S0 <= '1';

S1 <= '1';

S2 <= '1';

end process;

END;

## Register 16 bit:

Turns load on, puts 0xFFFF into the register, turns load off, turns load on, puts 0xAAAA into the register.

ENTITY reg16\_tb IS

END reg16\_tb;

ARCHITECTURE behavior OF reg16\_tb IS

-- Component Declaration for the Unit Under Test (UUT)

COMPONENT reg16

PORT(

D : IN std\_logic\_vector(15 downto 0);

load : IN std\_logic;

Clk : IN std\_logic;

Q : OUT std\_logic\_vector(15 downto 0)

);

END COMPONENT;

--Inputs

signal D : std\_logic\_vector(15 downto 0) := (others => '0');

signal load : std\_logic := '0';

signal Clk : std\_logic := '0';

--Outputs

signal Q : std\_logic\_vector(15 downto 0);

-- Clock period definitions

constant Clk\_period : time := 10 ns;

BEGIN

-- Instantiate the Unit Under Test (UUT)

uut: reg16 PORT MAP (

D => D,

load => load,

Clk => Clk,

Q => Q

);

-- Clock process definitions

Clk\_process :process

begin

Clk <= '0';

wait for Clk\_period/2;

Clk <= '1';

wait for Clk\_period/2;

end process;

-- Stimulus process

stim\_proc: process

begin

wait for 10ns;

D <= x"FFFF";

load <= '1';

wait for 10ns;

load <= '0';

wait for 10ns;

D <= x"AAAA";

load <= '1';

wait for 10ns;

load <= '0';

end process;

END;

## Register File with 8 16 bit registers:

Loads 0xFFFF into R0 with the load enable signal set to high. The load enable signal is set to low and we try to load 0xAAAA into R0 and fail.

**ENTITY** regfile\_16bit\_tb **IS**

**END** regfile\_16bit\_tb**;**

**ARCHITECTURE** behavior **OF** regfile\_16bit\_tb **IS**

-- Component Declaration for the Unit Under Test (UUT)

**COMPONENT** regfile\_16bit

**PORT(**

A\_Sel **:** **IN** std\_logic\_vector**(**2 **downto** 0**);**

B\_Sel **:** **IN** std\_logic\_vector**(**2 **downto** 0**);**

D\_Sel **:** **IN** std\_logic\_vector**(**2 **downto** 0**);**

A\_Data **:** **OUT** std\_logic\_vector**(**15 **downto** 0**);**

B\_Data **:** **OUT** std\_logic\_vector**(**15 **downto** 0**);**

D\_Data **:** **IN** std\_logic\_vector**(**15 **downto** 0**);**

Load\_En **:** **IN** std\_logic**;**

CLK **:** **IN** std\_logic

**);**

**END** **COMPONENT;**

--Inputs

**signal** A\_Sel **:** std\_logic\_vector**(**2 **downto** 0**)** **:=** **(others** **=>** '0'**);**

**signal** B\_Sel **:** std\_logic\_vector**(**2 **downto** 0**)** **:=** **(others** **=>** '0'**);**

**signal** D\_Sel **:** std\_logic\_vector**(**2 **downto** 0**)** **:=** **(others** **=>** '0'**);**

**signal** D\_Data **:** std\_logic\_vector**(**15 **downto** 0**)** **:=** **(others** **=>** '0'**);**

**signal** Load\_En **:** std\_logic **:=** '0'**;**

**signal** CLK **:** std\_logic **:=** '0'**;**

--Outputs

**signal** A\_Data **:** std\_logic\_vector**(**15 **downto** 0**);**

**signal** B\_Data **:** std\_logic\_vector**(**15 **downto** 0**);**

-- Clock period definitions

**constant** CLK\_period **:** time **:=** 10 ns**;**

**BEGIN**

-- Instantiate the Unit Under Test (UUT)

uut**:** regfile\_16bit **PORT** **MAP** **(**

A\_Sel **=>** A\_Sel**,**

B\_Sel **=>** B\_Sel**,**

D\_Sel **=>** D\_Sel**,**

A\_Data **=>** A\_Data**,**

B\_Data **=>** B\_Data**,**

D\_Data **=>** D\_Data**,**

Load\_En **=>** Load\_En**,**

CLK **=>** CLK

**);**

-- Clock process definitions

CLK\_process **:process**

**begin**

CLK **<=** '0'**;**

**wait** **for** CLK\_period**/**2**;**

CLK **<=** '1'**;**

**wait** **for** CLK\_period**/**2**;**

**end** **process;**

-- Stimulus process

stim\_proc**:** **process**

**begin**

D\_Data **<=** x"FFFF"**;**

Load\_En **<=** '1'**;**

D\_Sel**(**0**)** **<=** '0'**;**

D\_Sel**(**1**)** **<=** '0'**;**

D\_Sel**(**2**)** **<=** '0'**;**

**wait** **for** 10ns**;**

D\_data **<=** x"AAAA"**;**

Load\_En **<=** '0'**;**

D\_Sel**(**0**)** **<=** '0'**;**

D\_Sel**(**1**)** **<=** '0'**;**

D\_Sel**(**2**)** **<=** '0'**;**

**wait** **for** 10ns**;**

**end** **process;**

**END;**

## Full Adder:

Cycles through addition of all binary combinations of Cin, X and Y.

**ENTITY** full\_adder\_tb **IS**

**END** full\_adder\_tb**;**

**ARCHITECTURE** behavior **OF** full\_adder\_tb **IS**

-- Component Declaration for the Unit Under Test (UUT)

**COMPONENT** full\_adder

**PORT(**

X **:** **IN** std\_logic**;**

Y **:** **IN** std\_logic**;**

Cin **:** **IN** std\_logic**;**

Sum **:** **OUT** std\_logic**;**

Cout **:** **OUT** std\_logic

**);**

**END** **COMPONENT;**

--Inputs

**signal** X **:** std\_logic **:=** '0'**;**

**signal** Y **:** std\_logic **:=** '0'**;**

**signal** Cin **:** std\_logic **:=** '0'**;**

--Outputs

**signal** Sum **:** std\_logic**;**

**signal** Cout **:** std\_logic**;**

**BEGIN**

-- Instantiate the Unit Under Test (UUT)

uut**:** full\_adder **PORT** **MAP** **(**

X **=>** X**,**

Y **=>** Y**,**

Cin **=>** Cin**,**

Sum **=>** Sum**,**

Cout **=>** Cout

**);**

-- Stimulus process

stim\_proc**:** **process**

**begin**

Cin **<=** '0'**;**

Y **<=** '0'**;**

X **<=** '0'**;**

**wait** **for** 10ns**;**

Cin **<=** '1'**;**

Y **<=** '0'**;**

X **<=** '0'**;**

**wait** **for** 10ns**;**

Cin **<=** '0'**;**

Y **<=** '1'**;**

X **<=** '0'**;**

**wait** **for** 10ns**;**

Cin **<=** '1'**;**

Y **<=** '1'**;**

X **<=** '0'**;**

**wait** **for** 10ns**;**

Cin **<=** '0'**;**

Y **<=** '0'**;**

X **<=** '1'**;**

**wait** **for** 10ns**;**

Cin **<=** '1'**;**

Y **<=** '0'**;**

X **<=** '1'**;**

**wait** **for** 10ns**;**

Cin **<=** '0'**;**

Y **<=** '1'**;**

X **<=** '1'**;**

**wait** **for** 10ns**;**

Cin **<=** '1'**;**

Y **<=** '1'**;**

X **<=** '1'**;**

**wait** **for** 10ns**;**

**end** **process;**

**END;**

## Ripple Adder 16 bit:

Adds two positive numbers and then shows the operation of the overflow flag by adding two, two’s complement negative numbers to get a positive number.

**ENTITY** ripple\_adder\_16bit\_tb **IS**

**END** ripple\_adder\_16bit\_tb**;**

**ARCHITECTURE** behavior **OF** ripple\_adder\_16bit\_tb **IS**

-- Component Declaration for the Unit Under Test (UUT)

**COMPONENT** ripple\_adder\_16bit

**PORT(**

A **:** **IN** std\_logic\_vector**(**15 **downto** 0**);**

B **:** **IN** std\_logic\_vector**(**15 **downto** 0**);**

Cin **:** **IN** std\_logic**;**

V **:** **OUT** std\_logic**;**

Cout **:** **OUT** std\_logic**;**

G **:** **OUT** std\_logic\_vector**(**15 **downto** 0**)**

**);**

**END** **COMPONENT;**

--Inputs

**signal** A **:** std\_logic\_vector**(**15 **downto** 0**)** **:=** **(others** **=>** '0'**);**

**signal** B **:** std\_logic\_vector**(**15 **downto** 0**)** **:=** **(others** **=>** '0'**);**

**signal** Cin **:** std\_logic **:=** '0'**;**

--Outputs

**signal** V **:** std\_logic**;**

**signal** Cout **:** std\_logic**;**

**signal** G **:** std\_logic\_vector**(**15 **downto** 0**);**

**BEGIN**

-- Instantiate the Unit Under Test (UUT)

uut**:** ripple\_adder\_16bit **PORT** **MAP** **(**

A **=>** A**,**

B **=>** B**,**

Cin **=>** Cin**,**

V **=>** V**,**

Cout **=>** Cout**,**

G **=>** G

**);**

-- Stimulus process

stim\_proc**:** **process**

**begin**

A **<=** x"0001"**;**

B **<=** x"0001"**;**

Cin **<=** '0'**;**

**wait** **for** 10ns**;**

A **<=** x"8001"**;**

B **<=** x"8001"**;**

Cin **<=** '0'**;**

**wait** **for** 10ns**;**

**end** **process;**

**END;**

## B Input Logic:

Cycles through all the binary combinations of the select line.

**ENTITY** b\_input\_logic\_tb **IS**

**END** b\_input\_logic\_tb**;**

**ARCHITECTURE** behavior **OF** b\_input\_logic\_tb **IS**

-- Component Declaration for the Unit Under Test (UUT)

**COMPONENT** b\_input\_logic

**PORT(**

B **:** **IN** std\_logic\_vector**(**15 **downto** 0**);**

S **:** **IN** std\_logic\_vector**(**1 **downto** 0**);**

Y **:** **OUT** std\_logic\_vector**(**15 **downto** 0**)**

**);**

**END** **COMPONENT;**

--Inputs

**signal** B **:** std\_logic\_vector**(**15 **downto** 0**)** **:=** **(others** **=>** '0'**);**

**signal** S **:** std\_logic\_vector**(**1 **downto** 0**)** **:=** **(others** **=>** '0'**);**

--Outputs

**signal** Y **:** std\_logic\_vector**(**15 **downto** 0**);**

**BEGIN**

-- Instantiate the Unit Under Test (UUT)

uut**:** b\_input\_logic **PORT** **MAP** **(**

B **=>** B**,**

S **=>** S**,**

Y **=>** Y

**);**

-- Stimulus process

stim\_proc**:** **process**

**begin**

B **<=** x"AAAA"**;**

S**(**0**)** **<=** '0'**;**

S**(**1**)** **<=** '0'**;**

**wait** **for** 10ns**;**

S**(**0**)** **<=** '1'**;**

S**(**1**)** **<=** '0'**;**

**wait** **for** 10ns**;**

S**(**0**)** **<=** '0'**;**

S**(**1**)** **<=** '1'**;**

**wait** **for** 10ns**;**

S**(**0**)** **<=** '1'**;**

S**(**1**)** **<=** '1'**;**

**wait** **for** 10ns**;**

**end** **process;**

**END;**

## Arithmetic Unit:

Cycles through all of the arithmetic operations that can be performed on the two operands A and B.

**ENTITY** arithmetic\_unit\_tb **IS**

**END** arithmetic\_unit\_tb**;**

**ARCHITECTURE** behavior **OF** arithmetic\_unit\_tb **IS**

-- Component Declaration for the Unit Under Test (UUT)

**COMPONENT** arithmetic\_unit

**PORT(**

A **:** **IN** std\_logic\_vector**(**15 **downto** 0**);**

B **:** **IN** std\_logic\_vector**(**15 **downto** 0**);**

Cin **:** **IN** std\_logic**;**

SelB **:** **IN** std\_logic\_vector**(**1 **downto** 0**);**

G **:** **OUT** std\_logic\_vector**(**15 **downto** 0**);**

Cout **:** **OUT** std\_logic**;**

V **:** **OUT** std\_logic

**);**

**END** **COMPONENT;**

--Inputs

**signal** A **:** std\_logic\_vector**(**15 **downto** 0**)** **:=** **(others** **=>** '0'**);**

**signal** B **:** std\_logic\_vector**(**15 **downto** 0**)** **:=** **(others** **=>** '0'**);**

**signal** Cin **:** std\_logic **:=** '0'**;**

**signal** SelB **:** std\_logic\_vector**(**1 **downto** 0**)** **:=** **(others** **=>** '0'**);**

--Outputs

**signal** G **:** std\_logic\_vector**(**15 **downto** 0**);**

**signal** Cout **:** std\_logic**;**

**signal** V **:** std\_logic**;**

**BEGIN**

-- Instantiate the Unit Under Test (UUT)

uut**:** arithmetic\_unit **PORT** **MAP** **(**

A **=>** A**,**

B **=>** B**,**

Cin **=>** Cin**,**

SelB **=>** SelB**,**

G **=>** G**,**

Cout **=>** Cout**,**

V **=>** V

**);**

-- Stimulus process

stim\_proc**:** **process**

**begin**

A **<=** x"0002"**;**

B **<=** x"0001"**;**

**wait** **for** 10ns**;**

-- G = A (Transfer)

SelB**(**0**)** **<=** '0'**;**

SelB**(**1**)** **<=** '0'**;**

Cin **<=** '0'**;**

**wait** **for** 100ns**;**

-- G = A + 1 (Increment)

SelB**(**0**)** **<=** '0'**;**

SelB**(**1**)** **<=** '0'**;**

Cin **<=** '1'**;**

**wait** **for** 100ns**;**

-- G = A + B (Add)

SelB**(**0**)** **<=** '1'**;**

SelB**(**1**)** **<=** '0'**;**

Cin **<=** '0'**;**

**wait** **for** 100ns**;**

-- G = A + B + 1

SelB**(**0**)** **<=** '1'**;**

SelB**(**1**)** **<=** '0'**;**

Cin **<=** '1'**;**

**wait** **for** 100ns**;**

-- G = A + notB

SelB**(**0**)** **<=** '0'**;**

SelB**(**1**)** **<=** '1'**;**

Cin **<=** '0'**;**

**wait** **for** 100ns**;**

-- G = A + notB + 1 (Subtract)

SelB**(**0**)** **<=** '0'**;**

SelB**(**1**)** **<=** '1'**;**

Cin **<=** '1'**;**

**wait** **for** 100ns**;**

-- G = A - 1 (Decrement)

SelB**(**0**)** **<=** '1'**;**

SelB**(**1**)** **<=** '1'**;**

Cin **<=** '0'**;**

**wait** **for** 100ns**;**

-- G = A (Transfer)

SelB**(**0**)** **<=** '1'**;**

SelB**(**1**)** **<=** '1'**;**

Cin **<=** '1'**;**

**wait** **for** 100ns**;**

**end** **process;**

**END;**

## Logic Unit:

Performs the 4 operations AND, OR, XOR and NOT on the operands A and B.

**ENTITY** logic\_unit\_tb **IS**

**END** logic\_unit\_tb**;**

**ARCHITECTURE** behavior **OF** logic\_unit\_tb **IS**

-- Component Declaration for the Unit Under Test (UUT)

**COMPONENT** logic\_unit

**PORT(**

A **:** **IN** std\_logic\_vector**(**15 **downto** 0**);**

B **:** **IN** std\_logic\_vector**(**15 **downto** 0**);**

S **:** **IN** std\_logic\_vector**(**1 **downto** 0**);**

G **:** **OUT** std\_logic\_vector**(**15 **downto** 0**)**

**);**

**END** **COMPONENT;**

--Inputs

**signal** A **:** std\_logic\_vector**(**15 **downto** 0**)** **:=** **(others** **=>** '0'**);**

**signal** B **:** std\_logic\_vector**(**15 **downto** 0**)** **:=** **(others** **=>** '0'**);**

**signal** S **:** std\_logic\_vector**(**1 **downto** 0**)** **:=** **(others** **=>** '0'**);**

--Outputs

**signal** G **:** std\_logic\_vector**(**15 **downto** 0**);**

**BEGIN**

-- Instantiate the Unit Under Test (UUT)

uut**:** logic\_unit **PORT** **MAP** **(**

A **=>** A**,**

B **=>** B**,**

S **=>** S**,**

G **=>** G

**);**

-- Stimulus process

stim\_proc**:** **process**

**begin**

A **<=** x"1111"**;**

B **<=** x"0101"**;**

S**(**0**)** **<=** '0'**;**

S**(**1**)** **<=** '0'**;**

**wait** **for** 10ns**;**

S**(**0**)** **<=** '1'**;**

S**(**1**)** **<=** '0'**;**

**wait** **for** 10ns**;**

S**(**0**)** **<=** '0'**;**

S**(**1**)** **<=** '1'**;**

**wait** **for** 10ns**;**

S**(**0**)** **<=** '1'**;**

S**(**1**)** **<=** '1'**;**

**wait** **for** 10ns**;**

**end** **process;**

**END;**

## ALU:

Performs all of the arithmetic and logical operations on operands A and B.

**ENTITY** alu\_16bit\_tb **IS**

**END** alu\_16bit\_tb**;**

**ARCHITECTURE** behavior **OF** alu\_16bit\_tb **IS**

-- Component Declaration for the Unit Under Test (UUT)

**COMPONENT** alu\_16bit

**PORT(**

A **:** **IN** std\_logic\_vector**(**15 **downto** 0**);**

B **:** **IN** std\_logic\_vector**(**15 **downto** 0**);**

GSel **:** **IN** std\_logic\_vector**(**3 **downto** 0**);**

C **:** **OUT** std\_logic**;**

V **:** **OUT** std\_logic**;**

G **:** **OUT** std\_logic\_vector**(**15 **downto** 0**)**

**);**

**END** **COMPONENT;**

--Inputs

**signal** A **:** std\_logic\_vector**(**15 **downto** 0**)** **:=** **(others** **=>** '0'**);**

**signal** B **:** std\_logic\_vector**(**15 **downto** 0**)** **:=** **(others** **=>** '0'**);**

**signal** GSel **:** std\_logic\_vector**(**3 **downto** 0**)** **:=** **(others** **=>** '0'**);**

--Outputs

**signal** C **:** std\_logic**;**

**signal** V **:** std\_logic**;**

**signal** G **:** std\_logic\_vector**(**15 **downto** 0**);**

**BEGIN**

-- Instantiate the Unit Under Test (UUT)

uut**:** alu\_16bit **PORT** **MAP** **(**

A **=>** A**,**

B **=>** B**,**

GSel **=>** GSel**,**

C **=>** C**,**

V **=>** V**,**

G **=>** G

**);**

-- Stimulus process

stim\_proc**:** **process**

**begin**

------Arithmetic Ops-----------------------------------------

-- G = A

A **<=** x"0001"**;**

B **<=** x"0002"**;**

GSel**(**3**)** **<=** '0'**;**

GSel**(**2**)** **<=** '0'**;**

GSel**(**1**)** **<=** '0'**;**

GSel**(**0**)** **<=** '0'**;**

**wait** **for** 100ns**;**

-- G = A + 1

A **<=** x"0001"**;**

B **<=** x"0002"**;**

GSel**(**3**)** **<=** '0'**;**

GSel**(**2**)** **<=** '0'**;**

GSel**(**1**)** **<=** '0'**;**

GSel**(**0**)** **<=** '1'**;**

**wait** **for** 100ns**;**

-- G = A + B

A **<=** x"0001"**;**

B **<=** x"0002"**;**

GSel**(**3**)** **<=** '0'**;**

GSel**(**2**)** **<=** '0'**;**

GSel**(**1**)** **<=** '1'**;**

GSel**(**0**)** **<=** '0'**;**

**wait** **for** 100ns**;**

-- G = A + B + 1

A **<=** x"0001"**;**

B **<=** x"0002"**;**

GSel**(**3**)** **<=** '0'**;**

GSel**(**2**)** **<=** '0'**;**

GSel**(**1**)** **<=** '1'**;**

GSel**(**0**)** **<=** '1'**;**

**wait** **for** 100ns**;**

-- G = A + notB

A **<=** x"0001"**;**

B **<=** x"0002"**;**

GSel**(**3**)** **<=** '0'**;**

GSel**(**2**)** **<=** '1'**;**

GSel**(**1**)** **<=** '0'**;**

GSel**(**0**)** **<=** '0'**;**

**wait** **for** 100ns**;**

-- G = A - B

A **<=** x"0001"**;**

B **<=** x"0002"**;**

GSel**(**3**)** **<=** '0'**;**

GSel**(**2**)** **<=** '1'**;**

GSel**(**1**)** **<=** '0'**;**

GSel**(**0**)** **<=** '1'**;**

**wait** **for** 100ns**;**

-- G = A - 1

A **<=** x"0001"**;**

B **<=** x"0002"**;**

GSel**(**3**)** **<=** '0'**;**

GSel**(**2**)** **<=** '1'**;**

GSel**(**1**)** **<=** '1'**;**

GSel**(**0**)** **<=** '0'**;**

**wait** **for** 100ns**;**

-- G = A

A **<=** x"0001"**;**

B **<=** x"0002"**;**

GSel**(**3**)** **<=** '0'**;**

GSel**(**2**)** **<=** '1'**;**

GSel**(**1**)** **<=** '1'**;**

GSel**(**0**)** **<=** '1'**;**

**wait** **for** 100ns**;**

------Logical Ops--------------------------------------------

-- G = A and B

A **<=** x"0001"**;**

B **<=** x"0002"**;**

GSel**(**3**)** **<=** '1'**;**

GSel**(**2**)** **<=** '0'**;** -- S1 is don't care for all logical ops

GSel**(**1**)** **<=** '0'**;**

GSel**(**0**)** **<=** '0'**;**

**wait** **for** 100ns**;**

-- G = A or B

A **<=** x"0001"**;**

B **<=** x"0002"**;**

GSel**(**3**)** **<=** '1'**;**

GSel**(**2**)** **<=** '0'**;**

GSel**(**1**)** **<=** '1'**;**

GSel**(**0**)** **<=** '0'**;**

**wait** **for** 100ns**;**

-- G = A xor B

A **<=** x"0001"**;**

B **<=** x"0002"**;**

GSel**(**3**)** **<=** '1'**;**

GSel**(**2**)** **<=** '1'**;**

GSel**(**1**)** **<=** '0'**;**

GSel**(**0**)** **<=** '0'**;**

**wait** **for** 100ns**;**

-- G = notA

A **<=** x"0001"**;**

B **<=** x"0002"**;**

GSel**(**3**)** **<=** '1'**;**

GSel**(**2**)** **<=** '1'**;**

GSel**(**1**)** **<=** '1'**;**

GSel**(**0**)** **<=** '0'**;**

**wait** **for** 100ns**;**

**end** **process;**

**END;**

## Shifter:

Performs a pass-through, left shift and right shift on B with also a demonstration of the IR and IL inputs being shifted into B.

**ENTITY** shifter\_16bit\_tb **IS**

**END** shifter\_16bit\_tb**;**

**ARCHITECTURE** behavior **OF** shifter\_16bit\_tb **IS**

-- Component Declaration for the Unit Under Test (UUT)

**COMPONENT** shifter\_16bit

**PORT(**

B **:** **IN** std\_logic\_vector**(**15 **downto** 0**);**

S **:** **IN** std\_logic\_vector**(**1 **downto** 0**);**

IR **:** **IN** std\_logic**;**

IL **:** **IN** std\_logic**;**

H **:** **OUT** std\_logic\_vector**(**15 **downto** 0**)**

**);**

**END** **COMPONENT;**

--Inputs

**signal** B **:** std\_logic\_vector**(**15 **downto** 0**)** **:=** **(others** **=>** '0'**);**

**signal** S **:** std\_logic\_vector**(**1 **downto** 0**)** **:=** **(others** **=>** '0'**);**

**signal** IR **:** std\_logic **:=** '0'**;**

**signal** IL **:** std\_logic **:=** '0'**;**

--Outputs

**signal** H **:** std\_logic\_vector**(**15 **downto** 0**);**

**BEGIN**

-- Instantiate the Unit Under Test (UUT)

uut**:** shifter\_16bit **PORT** **MAP** **(**

B **=>** B**,**

S **=>** S**,**

IR **=>** IR**,**

IL **=>** IL**,**

H **=>** H

**);**

-- Stimulus process

stim\_proc**:** **process**

**begin**

-- B pass through

B **<=** x"0001"**;**

S**(**0**)** **<=** '0'**;**

S**(**1**)** **<=** '0'**;**

**wait** **for** 10ns**;**

-- B right shift

B **<=** x"0002"**;**

S**(**0**)** **<=** '1'**;**

S**(**1**)** **<=** '0'**;**

**wait** **for** 10ns**;**

-- B left shift

B **<=** x"0002"**;**

S**(**0**)** **<=** '0'**;**

S**(**1**)** **<=** '1'**;**

**wait** **for** 10ns**;**

-- B right shift with input on IR

B **<=** x"0002"**;**

S**(**0**)** **<=** '1'**;**

S**(**1**)** **<=** '0'**;**

IL **<=** '0'**;**

IR **<=** '1'**;**

**wait** **for** 10ns**;**

-- B left shift with input on IL

B **<=** x"0002"**;**

S**(**0**)** **<=** '0'**;**

S**(**1**)** **<=** '1'**;**

IL **<=** '1'**;**

IR **<=** '0'**;**

**wait** **for** 10ns**;**

IL **<=** '0'**;**

IR **<=** '0'**;**

**end** **process;**

**END;**

## Function Unit:

Performs the arithmetic and logical operations as the previous test benches have with the addition of updating the Carry, Overflow, Zero and Negative control flags.

**ENTITY** function\_unit\_tb **IS**

**END** function\_unit\_tb**;**

**ARCHITECTURE** behavior **OF** function\_unit\_tb **IS**

-- Component Declaration for the Unit Under Test (UUT)

**COMPONENT** function\_unit

**PORT(**

A **:** **IN** std\_logic\_vector**(**15 **downto** 0**);**

B **:** **IN** std\_logic\_vector**(**15 **downto** 0**);**

FSel **:** **IN** std\_logic\_vector**(**4 **downto** 0**);**

C **:** **OUT** std\_logic**;**

V **:** **OUT** std\_logic**;**

N **:** **OUT** std\_logic**;**

Z **:** **OUT** std\_logic**;**

F **:** **OUT** std\_logic\_vector**(**15 **downto** 0**)**

**);**

**END** **COMPONENT;**

--Inputs

**signal** A **:** std\_logic\_vector**(**15 **downto** 0**)** **:=** **(others** **=>** '0'**);**

**signal** B **:** std\_logic\_vector**(**15 **downto** 0**)** **:=** **(others** **=>** '0'**);**

**signal** FSel **:** std\_logic\_vector**(**4 **downto** 0**)** **:=** **(others** **=>** '0'**);**

--Outputs

**signal** C **:** std\_logic**;**

**signal** V **:** std\_logic**;**

**signal** N **:** std\_logic**;**

**signal** Z **:** std\_logic**;**

**signal** F **:** std\_logic\_vector**(**15 **downto** 0**);**

**BEGIN**

-- Instantiate the Unit Under Test (UUT)

uut**:** function\_unit **PORT** **MAP** **(**

A **=>** A**,**

B **=>** B**,**

FSel **=>** FSel**,**

C **=>** C**,**

V **=>** V**,**

N **=>** N**,**

Z **=>** Z**,**

F **=>** F

**);**

-- Stimulus process

stim\_proc**:** **process**

**begin**

-- TRANSFER A

A **<=** x"0001"**;**

B **<=** x"0002"**;**

FSel **<=** "00000"**;**

**wait** **for** 100ns**;** -- F = 0000 0001

-- INCREMENT

A **<=** x"0001"**;**

B **<=** x"0002"**;**

FSel **<=** "00001"**;**

**wait** **for** 100ns**;** -- F = 0000 0010

-- ADD

A **<=** x"0001"**;**

B **<=** x"0002"**;**

FSel **<=** "00010"**;**

**wait** **for** 100ns**;** -- F = 0000 0011

-- ADD WITH CARRY

A **<=** x"0001"**;**

B **<=** x"0002"**;**

FSel **<=** "00011"**;**

**wait** **for** 100ns**;** -- F = 0000 0100

-- ADD WITH NOT B

A **<=** x"0001"**;**

B **<=** x"0002"**;**

FSel **<=** "00100"**;**

**wait** **for** 100ns**;** -- F = 1111 1110

-- SUBTRACT

A **<=** x"0001"**;**

B **<=** x"0002"**;**

FSel **<=** "00101"**;**

**wait** **for** 100ns**;** -- F = 1111 1111

-- DECREMENT

A **<=** x"0001"**;**

B **<=** x"0002"**;**

FSel **<=** "00110"**;**

**wait** **for** 100ns**;** -- F = 0000 0000

-- TRANSFER A

A **<=** x"0001"**;**

B **<=** x"0002"**;**

FSel **<=** "00111"**;**

**wait** **for** 100ns**;** -- F = 0000 0001

-- AND

A **<=** x"0001"**;**

B **<=** x"0002"**;**

FSel **<=** "01000"**;**

**wait** **for** 100ns**;** -- F = 0000 0000

-- OR

A **<=** x"0001"**;**

B **<=** x"0002"**;**

FSel **<=** "01010"**;**

**wait** **for** 100ns**;** -- F = 0000 0011

-- XOR

A **<=** x"0001"**;**

B **<=** x"0002"**;**

FSel **<=** "01100"**;**

**wait** **for** 100ns**;** -- F = 0000 0011

-- NOT

A **<=** x"0001"**;**

B **<=** x"0002"**;**

FSel **<=** "01110"**;**

**wait** **for** 100ns**;** -- F = 1111 1110

-- TRANSFER B

A **<=** x"0001"**;**

B **<=** x"0002"**;**

FSel **<=** "10000"**;**

**wait** **for** 100ns**;** -- F = 0000 0010

-- SHIFT RIGHT (also displays carry)

A **<=** x"0001"**;**

B **<=** x"F002"**;**

FSel **<=** "10100"**;**

**wait** **for** 100ns**;** -- F = 0000 0001

-- SHIFT LEFT (also displays carry)

A **<=** x"0001"**;**

B **<=** x"F002"**;**

FSel **<=** "11000"**;**

**wait** **for** 100ns**;** -- F = 0000 0100

**end** **process;**

**END;**

## Datapath:

Shows the use of the Control Word to perform tow load operations on R0 and R1, and an arithmetic addition between R0 and R1 into R2. We can use the ADDR\_OUT to view R2.

**ENTITY** datapath\_16bit\_tb **IS**

**END** datapath\_16bit\_tb**;**

**ARCHITECTURE** behavior **OF** datapath\_16bit\_tb **IS**

-- Component Declaration for the Unit Under Test (UUT)

**COMPONENT** datapath\_16bit

**PORT(**

CONTROL\_WORD **:** **IN** std\_logic\_vector**(**16 **downto** 0**);**

CONST\_IN **:** **IN** std\_logic\_vector**(**15 **downto** 0**);**

DATA\_IN **:** **IN** std\_logic\_vector**(**15 **downto** 0**);**

CLK **:** **IN** std\_logic**;**

ADDR\_OUT **:** **OUT** std\_logic\_vector**(**15 **downto** 0**);**

DATA\_OUT **:** **OUT** std\_logic\_vector**(**15 **downto** 0**);**

C **:** **OUT** std\_logic**;**

V **:** **OUT** std\_logic**;**

N **:** **OUT** std\_logic**;**

Z **:** **OUT** std\_logic

**);**

**END** **COMPONENT;**

--Inputs

**signal** CONTROL\_WORD **:** std\_logic\_vector**(**16 **downto** 0**)** **:=** **(others** **=>** '0'**);**

**signal** CONST\_IN **:** std\_logic\_vector**(**15 **downto** 0**)** **:=** **(others** **=>** '0'**);**

**signal** DATA\_IN **:** std\_logic\_vector**(**15 **downto** 0**)** **:=** **(others** **=>** '0'**);**

**signal** CLK **:** std\_logic **:=** '0'**;**

--Outputs

**signal** ADDR\_OUT **:** std\_logic\_vector**(**15 **downto** 0**);**

**signal** DATA\_OUT **:** std\_logic\_vector**(**15 **downto** 0**);**

**signal** C **:** std\_logic**;**

**signal** V **:** std\_logic**;**

**signal** N **:** std\_logic**;**

**signal** Z **:** std\_logic**;**

-- Clock period definitions

**constant** CLK\_period **:** time **:=** 10 ns**;**

**BEGIN**

-- Instantiate the Unit Under Test (UUT)

uut**:** datapath\_16bit **PORT** **MAP** **(**

CONTROL\_WORD **=>** CONTROL\_WORD**,**

CONST\_IN **=>** CONST\_IN**,**

DATA\_IN **=>** DATA\_IN**,**

CLK **=>** CLK**,**

ADDR\_OUT **=>** ADDR\_OUT**,**

DATA\_OUT **=>** DATA\_OUT**,**

C **=>** C**,**

V **=>** V**,**

N **=>** N**,**

Z **=>** Z

**);**

-- Clock process definitions

CLK\_process **:process**

**begin**

CLK **<=** '0'**;**

**wait** **for** CLK\_period**/**2**;**

CLK **<=** '1'**;**

**wait** **for** CLK\_period**/**2**;**

**end** **process;**

-- Stimulus process

stim\_proc**:** **process**

**begin**

-- R0 = 0x0001

CONTROL\_WORD **<=** "00000000010000011"**;**

DATA\_IN **<=** x"0001"**;**

**wait** **for** 20ns**;**

-- R1 = 0x0002

CONTROL\_WORD **<=** "00100100010000011"**;**

DATA\_IN **<=** x"0002"**;**

**wait** **for** 20ns**;**

-- R2 = R0 + R1

CONTROL\_WORD **<=** "01000000100001001"**;**

**wait** **for** 20ns**;**

-- Observe R2 on ADDR\_OUT

CONTROL\_WORD **<=** "01001000000000001"**;**

**wait** **for** 40ns**;**

**end** **process;**

**END;**

# VHDL Test Bench Images:

## C:\Users\JackCassidy\AppData\Local\Microsoft\Windows\INetCacheContent.Word\decodertb.pngDecoder 3 to 8 16bit:

## C:\Users\JackCassidy\AppData\Local\Microsoft\Windows\INetCacheContent.Word\mux2_16bit_tb.pngMUX2 16bit:

## C:\Users\JackCassidy\AppData\Local\Microsoft\Windows\INetCache\Content.Word\mux3.pngMUX3 1 bit:

## C:\Users\JackCassidy\AppData\Local\Microsoft\Windows\INetCacheContent.Word\mux8_16bit_tb.pngMUX8 16bit:

## C:\Users\JackCassidy\AppData\Local\Microsoft\Windows\INetCacheContent.Word\reg16tb.pngRegister 16bit:

## C:\Users\JackCassidy\AppData\Local\Microsoft\Windows\INetCache\Content.Word\regfile.pngRegister File:

## C:\Users\JackCassidy\AppData\Local\Microsoft\Windows\INetCache\Content.Word\ripple adder.pngRipple Adder:

## C:\Users\JackCassidy\AppData\Local\Microsoft\Windows\INetCache\Content.Word\b input logic.pngB Input Logic:

## C:\Users\JackCassidy\AppData\Local\Microsoft\Windows\INetCache\Content.Word\arithmetic unit 2.pngC:\Users\JackCassidy\AppData\Local\Microsoft\Windows\INetCache\Content.Word\arithmetic unit 1.pngArithmetic Unit:

## C:\Users\JackCassidy\AppData\Local\Microsoft\Windows\INetCache\Content.Word\logic unit.pngLogic Unit:

## C:\Users\JackCassidy\AppData\Local\Microsoft\Windows\INetCache\Content.Word\alu 3.pngC:\Users\JackCassidy\AppData\Local\Microsoft\Windows\INetCache\Content.Word\alu 1.pngALU:C:\Users\JackCassidy\AppData\Local\Microsoft\Windows\INetCache\Content.Word\alu 2.png

## C:\Users\JackCassidy\AppData\Local\Microsoft\Windows\INetCache\Content.Word\shifter.pngShifter:

## C:\Users\JackCassidy\AppData\Local\Microsoft\Windows\INetCache\Content.Word\function unit 1.pngFunction Unit:

![C:\Users\JackCassidy\AppData\Local\Microsoft\Windows\INetCache\Content.Word\function unit 3.png](data:image/png;base64,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)![C:\Users\JackCassidy\AppData\Local\Microsoft\Windows\INetCache\Content.Word\function unit 2.png](data:image/png;base64,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6NrJQ9du5eH/wb1S/kIAaI/MeU5hijiC54w35nG/IfvuI13koQt56EIeupCHLuShSxbyKBSmIXPtDetDF/LQhTx0CeRhT1bCXwgA7ZE5zylMEUfwnPHGPFwgdSEPXchDF/LQhTx0IQ9dspAHhSnSQh66kIcugTzsSQClhRWmQCkUptlBHrqQhy7koQt56EIeumQhDwpTpIU8dCEPXQJ52JMASqMwRVwUptlBHrqQhy7koQt56EIeumQhDwpTpIU8dCEPXQJ52JNtrWPHjtKlS5fQOUAjClPERWGaHeShC3noQh66kIcu5KFLFvKgMEVayEMX8tAlkIc9WS1fq18Q6dQxc+XYY4+Vgw46SDp37izfPKGHnHb1HdZjwo4JaEBhirhaLEzZ1ezkoWsnD107eejayUPXTh669izkUShMa2BnfejayUPXTh66disP/w/u1fT7HftcLzl+t/1jeWrLXlny5ody77rdbiH6nctvlC996Uvy5S9/WQaMnOKOveg8duXbH8uTf94TekxAAwpTxNViYeq7j3SRhy7koQt56EIeupCHLlnIg3eYIi3koQt56BLIw56slufe/thlCtDlf9krj/zpI/nZ2t1y26qdctWSDW5B2q9fP+nfv790G7NAfvnKdvexv/7zHnlgwwehxwQ0oDBFXBSm2UEeupCHLuShC3noQh66ZCEPClOkhTx0IQ9dAnnYkwsWLLTut9YTTR/l7XHL0nvXvS+zVr0r4xr/IvWPNsl/Tn9SvnntQjl16iNy4R3LZfmWvfLU5r3yqz9+KPNXvxd6zJx6aZQmaaiLmjNbo9Sb+3UNziODj/Uek9+aGqSuMOepk4am/Lz3fPdY5m7Y41FLKEwRF4VpdpCHLuShC3noQh6l+F/v538uSHg8l0fbf962GffNWz8LtfT49GRhfVCYIi3koQt56BLIw540haknOBfHL974wHX/+g/kp2vel1kv7pIxv94qQxf/SS56YJOcf8+r8u0pD8vldy2XH/12izzZtEcefWuP/O/a92Xq8ztDj5ljLswlCtP8RbzONJ5Npi4NK0xLX9Dd5zbWN98uvDAIvkhALYpTmDYX78XnHHNma4s578V88XOMUsesFgrT7CAPXchDF/LQhTyi1TsX/sb63G3/6/okx00eaXzethgv3Deb72ehUo9PWxbWB4Up0kIeupCHLoE87ElT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)

## C:\Users\JackCassidy\AppData\Local\Microsoft\Windows\INetCache\Content.Word\datapath.pngDatapath: